# Go常用方法总结
# 1 判断类型是否一样
reflect.TypeOf(a).Kind() == reflect.TypeOf(b).Kind()
# 2 判断两个interface{}是否相等
reflect.DeepEqual(a, b interface{})
# 3 将一个interface{}赋值给另一个interface{}
reflect.ValueOf(a).Elem().Set(reflect.ValueOf(b))
# 4 strconv包简介
在Go语言中,我们往往需要对一些常用的数据类型进行转换,如string,int,int64 ,float等数据类型之间的转换,基于此Go语言为我们提供了一个名为strconv的包来为我们提供这些类型的转换方法。
# 4.1 string转化成int类型
Atoi() 将字符串类型的整数转换为int类型。
func Atoi(s string) (i int, err error)
如果传入的字符串参数无法转换为int类型,就会返回错误。
s1 := "100"
i1, err := strconv.Atoi(s1)
if err != nil {
fmt.Println("can't convert to int")
} else {
fmt.Printf("type:%T value:%#v\n", i1, i1) //type:int value:100
}
2
3
4
5
6
7
# 4.2 int类型转化成字符串string
Itoa() 将int类型数据转换为对应的字符串表示。
func Itoa(i int) string
i2 := 200
s2 := strconv.Itoa(i2)
fmt.Printf("type:%T value:%#v\n", s2, s2) //type:string value:"200"
2
3
# 4.3 Parse系列函数
Parse类函数用于转换字符串为给定类型的值:ParseBool()、ParseFloat()、ParseInt()、ParseUint()。
ParseFloat()
func ParseBool(str string) (value bool, err error)
返回字符串表示的bool值。它接受1、0、t、f、T、F、true、false、True、False、TRUE、FALSE;否则返回错误
ParseInt()
func ParseInt(s string, base int, bitSize int) (i int64, err error)
返回字符串表示的整数值,接受正负号。 base指定进制(2到36),如果base为0,则会从字符串前置判断,”0x”是16进制,”0”是8进制,否则是10进制; bitSize指定结果必须能无溢出赋值的整数类型,0、8、16、32、64 分别代表 int、int8、int16、int32、int64; 返回的err是*NumErr类型的,如果语法有误,err.Error = ErrSyntax;如果结果超出类型范围err.Error = ErrRange。
ParseFloat()
func ParseFloat(s string, bitSize int) (f float64, err error)
解析一个表示浮点数的字符串并返回其值。 如果s合乎语法规则,函数会返回最为接近s表示值的一个浮点数(使用IEEE754规范舍入)。 bitSize指定了期望的接收类型,32是float32(返回值可以不改变精确值的赋值给float32),64是float64; 返回值err是*NumErr类型的,语法有误的,err.Error=ErrSyntax;结果超出表示范围的,返回值f为±Inf,err.Error= ErrRange。
b, err := strconv.ParseBool("true")
f, err := strconv.ParseFloat("3.1415", 64)
i, err := strconv.ParseInt("-2", 10, 64)
u, err := strconv.ParseUint("2", 10, 64)
2
3
4
# 4.4 Format系列函数
Format系列函数实现了将给定类型数据格式化为string类型数据的功能
FormatBool() 根据b的值返回”true”或”false”。
func FormatBool(b bool) string
FormatInt() 返回i的base进制的字符串表示。base 必须在2到36之间,结果中会使用小写字母’a’到’z’表示大于10的数字。
func FormatInt(i int64, base int) string
FormatUint() 是FormatInt的无符号整数版本
func FormatUint(i uint64, base int) string
FormatFloat() 函数将浮点数表示为字符串并返回。
func FormatFloat(f float64, fmt byte, prec, bitSize int) string
← fmt.Printf总结 Go语言结构体 →